

# **Branches**

### R. Ferrero Politecnico di Torino

Dipartimento di Automatica e Informatica (DAUIN)

Torino - Italy

This work is licensed under the Creative Commons (CC BY-SA) License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/3.0/



#### **Unconditional branch**

 There are four instructions for unconditional branch:

```
    branch
    branch indirect
    branch and link
    branch indirect with link
    BLX <Rn>
```

• BL and BLX save the return address (i.e., the address of the next instruction) in LR (r14) and they are used to call subroutines.

# **Infinite loops**

- A stand-alone program, without operating system, can not continue beyond the end, otherwise the behavior is unpredictable.
- An infinite loop is added as last instruction:

```
stop B stop
```

or

```
LDR r1, =stop stop BX r1
```

#### LDR Vs ADR with BX

- Instructions are 16 or 32 bits long, so their address is always halfword aligned.
- BX requires that the last bit of the register is
   1) otherwise a usage fault exception is raised.
- BX jumps to the address created by changing the last bit of the register to 0.
- LDR sets the last bit to 1 if the label is in a code area, to 0 if the label is in a data area.
- ADR and ADRL do not change the last bit.

# LDR Vs ADR: example

0x00000CC 1.

LDR r1, =stop **0x00000CE** | stop BX r1

Ok: r1 = 0x000000CF

0x00000CC 2.

0x00000D4

ADRL r1, stop stop BX r1

No: r1 = 0x000000D4

0x00000CC 3.

0x00000D4

0x000000D8

ADRL r1, stop ORR r1, r1, #1 stop BX r1

Ok: r1 = 0x000000D9

## **Branch range**

- In the **B** instruction, the opcode is 8 bit and the immediate value is 24 bit.
- Since addresses are halfword-aligned, the immediate value specifies bit 24-1 of the relative address.
- The 25<sup>th</sup> is for the sign; so the relative address can be  $\pm 2^{24}$  byte =  $\pm 16$  MB.
- BX can jump to any 32-bit value = 4 GB.

Bx pué reltere più "lontono"

#### **MOV** for unconditional branch

- B and BX change the value of PC.
- Similarly, a jump can be implemented by changing the value of PC with MOV and LDR:

- MOV and LDR force the last bit of PC to 0.
- MOV instead of BX is discouraged: the assembler generates a warning.

#### Conditional branch: B?? and BX??

| ??       | Flags            | Meaning    | ??       | Flags                 | Meaning       |
|----------|------------------|------------|----------|-----------------------|---------------|
| EQ       | Z = 1            | equal      | NE       | Z = 0                 | not equal     |
| CS<br>HS | C = 1            | unsigned ≥ | CC<br>LO | C = 0                 | unsigned <    |
| MI       | N = 1            | negative   | PL       | N = 0                 | positive or 0 |
| VS       | V = 1            | overflow   | VC       | V = 0                 | no overflow   |
| ні       | C = 1 & Z = 0    | unsigned > | LS       | C =0 &<br>Z = 1       | unsigned ≤    |
| GE       | $N \ge V$        | signed ≥   | LT       | $N \neq V$            | signed <      |
| GT       | Z =0 or<br>N = V | signed >   | LE       | $Z = 1$ or $N \neq V$ | signed ≤      |

## Example: do you pass the exam?

```
; r0 contains the score of the exam
        CMP r0, #18
        BEQ refuse
        BLO reject
        BHI accept
refuse
                 ; study more
reject ...
                 ; study much more
                 ; go on holiday
accept
```

# Compare and branch

Compare and branch if Zero:

$$CBZ < Rn >$$
, < label>
jumps to label if Rn = 0

Compare and branch if Nonzero:

jumps to label if 
$$Rn \neq 0$$

- Rn must be among r0-r7.
- Only forward branch is possible (4-130 byte).

#### **CBZ-CBNZ Vs conditional branch**

These instructions are almost equivalent:

CBNZ r0, myLabel 
$$\frac{\text{CMP r0, } \#0}{\text{BNE myLabel}}$$

- Differences:
  - CMP sets the flags, while CBZ and CBNZ do not.
  - CBZ and CBNZ jump only forward, range is shorter
  - CBZ and CBNZ cannot be used within an IT block.

## While loop

The pseudocode of the while loop is

# While loop: implementation

```
B test
loop ... ; do something test CMP r0, #N
      BNE loop
test CMP r0, #N
      BE exit
        . ; do something
      B test
```

# While loop with CBZ

If N = 0, an alternative implementation using CBZ is:

```
loop CBZ r0, exit

do something

B loop

exit

...
```

# For loop

The pseudocode of the for loop is

# For loop: naive implementation

```
MOV r0, #0
     CMP r0, #N
loop
       BHS exit
                ; do something
       ADD r0, r0, #1
      NB loop
```

## For loop: optimization

```
MOV r0, N

loop ... ; do something

SUBS r0, r0, #1

BNE loop

exit
```

• CBNZ r0, loop can not be used instead of BNE loop because the branch is backward.

## **Do-While loop**

#### The pseudocode

loop ... ; do something test CMP r0, #N

BNE loop

## Example: absolute value of N - M

```
MOV rO, #N
        MOV r1, \#M
        CMP r0, r1
       BLT neg
        SUB r0, r0, r1
        B exit
      SUB r1, r1, r0
neg
               ; program continues
```

# Branch penalty if N < M



# Conditional execution (IT le une rela il compilatore, moi mon) deblicame verivela

 The IT (If-Then) block avoids branch penalty because there is no change to program flow:

```
ITxyz <cond>
instr1<cond> <operands>
instr2<cond OR not cond> <operands>
instr3<cond OR not cond> <operands>
instr4<cond OR not cond> <operands>
```

#### **Absolute value of N – M with IT**

```
MOV rO, #N
        MOV r1, \#M
        CMP r0, r1
        ITE GE
        SUBGE r0, r0, r1
        SUBLT r1, r1, r0
exit
        ... ; program continues
```

## No branch penalty



# IT syntax

- first statement after IT must be the true case
- up to 4 instructions (true or false) are allowed
- the number of instructions in true and false cases must match the number of T and E
- false condition is inverse of true condition
- branches to IT instructions are not allowed
- an IT instruction can be a branch only if it is the last one.